http://llvm.org/bugs/show_bug.cgi?id=10248 git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@134327 91177308-0d34-0410-b5e6-96231b3b80d8 
diff --git a/include/__bit_reference b/include/__bit_reference index 57b92ea..d62bec7 100644 --- a/include/__bit_reference +++ b/include/__bit_reference 
@@ -21,7 +21,13 @@  template <class _C, bool _IsConst> class __bit_iterator;  template <class _C> class __bit_const_reference;   -template <class _C> +template <class _Tp> +struct __has_storage_type +{ + static const bool value = false; +}; + +template <class _C, bool = __has_storage_type<_C>::value>  class __bit_reference  {  typedef typename _C::__storage_type __storage_type; @@ -66,6 +72,11 @@  : __seg_(__s), __mask_(__m) {}  };   +template <class _C> +class __bit_reference<_C, false> +{ +}; +  template <class _C, class _D>  _LIBCPP_INLINE_VISIBILITY inline  void 
diff --git a/include/bitset b/include/bitset index de0a201..f0e8027 100644 --- a/include/bitset +++ b/include/bitset 
@@ -130,6 +130,15 @@  _LIBCPP_BEGIN_NAMESPACE_STD    template <size_t _N_words, size_t _Size> +class __bitset; + +template <size_t _N_words, size_t _Size> +struct __has_storage_type<__bitset<_N_words, _Size> > +{ + static const bool value = true; +}; + +template <size_t _N_words, size_t _Size>  class __bitset  {  public: 
diff --git a/include/vector b/include/vector index 0bd82ea..d8c9feb 100644 --- a/include/vector +++ b/include/vector 
@@ -1749,6 +1749,12 @@  template <class _Allocator> struct hash<vector<bool, _Allocator> >;    template <class _Allocator> +struct __has_storage_type<vector<bool, _Allocator> > +{ + static const bool value = true; +}; + +template <class _Allocator>  class _LIBCPP_VISIBLE vector<bool, _Allocator>  : private __vector_base_common<true>  { @@ -1757,8 +1763,6 @@  typedef bool value_type;  typedef _Allocator allocator_type;  typedef allocator_traits<allocator_type> __alloc_traits; - typedef __bit_reference<vector> reference; - typedef __bit_const_reference<vector> const_reference;  typedef typename __alloc_traits::size_type size_type;  typedef typename __alloc_traits::difference_type difference_type;  typedef __bit_iterator<vector, false> pointer; @@ -1798,6 +1802,9 @@  size_type __size_;  __compressed_pair<size_type, __storage_allocator> __cap_alloc_;   + typedef __bit_reference<vector> reference; + typedef __bit_const_reference<vector> const_reference; +  _LIBCPP_INLINE_VISIBILITY  size_type& __cap() _NOEXCEPT  {return __cap_alloc_.first();}